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CALL ESTABLISHMENT 

The present invention relates to a technique for establishing a telephone 
connection between at least two end-points. The invention Is particularly, but not 
5 exclusively, concerned with establishing telephone calls between parties. 

Access to traditional long-distance telephone sen/ices is strictly limited to 
countries of origin. International phone rates vary from country to country, and are 
dependent on factors such as competition. l\4oblle telephone users may roam 
10 outside their home country, but usually pay a roaming charge plus expensive long- 
distance rates. 

Although there exists, In many countries, strong competition for the provision 
of long-distance telephone services, the current best rates for various countries may 
be provided by different caniers. For example, for a call made from the UK the best 

15 long-distance rate to Australia may be offered by one carrier, and the best long- 
distance rate to Brazil offered by another, different carrier. Thus a customer may 
have to research every telephone call to get the best rate. Furthermore, caniers are 
typically associated with one type of call. A earner that offers the best rate for a call 
from the UK to Australia may only do so for fixed line calls, and mobile telephone 

20 users may not be provided with low rate calls. 

There have been proposed various techniques for providing low-cost, best- 
cost, telephone services on an automated basis. 

There exists techniques for establishing long-distance voice communications 
using the internet. U.S. Patent No. 6.188.683 discloses a technique for establishing 
25 long-distance telephone calls over the public switched telephone networic using an 
automated internet operator. The system Includes a long-distance service provider 
node connected to the internet, and a call connection control computer connected to 
the internet and interfaced to a toll switch connected to the PSTN. The method 
permits a calling party to request the automated Intemet operator to complete long- 
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distance call connections by connecting to the long-distance service provider node 
and Identifying himself. The caller additionally provides the Identity of a called party. 
A call connection control computer Instructs the toll switch to dial the calling party, 
dial the called party, and then conference the two established lines. The 
5 conferencing of the two lines takes place In a PSTN toll switch. The call control 
computer Is adapted to utilise a "least cosr routing algorithm to select an Inter- 
exchange carrier for each call, depending on the origination and termination location 
of the call. All calls are established exclusively utilising an access to an Internet 
website. 

10 The technique disclosed In U.S. Patent No. 6,188,683 has two distinct 

drawbacks. Firstly, the connection of the two parties Is by conferencing In a PSTN' 
toll switch. When using a toll switch, a PSTN Instrument Is being Instructed to 
establish the calls using traditional signalling, and then to perform blending, intemally, 
of these earner signals. This means that the conversations themselves can only exist 

15 within the toll switch, in addition, driving a PSTN switch requires use of a proprietary 
protocol devised by the switch vendor. This ties any solution to using such switches, 
and also makes it difficult to build a distributed architecture. Secondly, the billing of 
the established call is based on the cost of the call from one party to the other. 

International patent application publication No. WO 02/078304 discloses a 
20 technique w.hlch Is a modification of the technique disclosed in U.S. Patent No. 
6,188.683. Specifically, a call Is established between two parties based on a request 
received In an electronic text message, rather than dlrectiy through a website. The 
connection again Is established by creating a telephone call to each party, and tiien 
bridging each party in a point of presence switch. 
25 This technique again disadvantageously utilises a PSTN switch, specifically a 

point of presence switch, to connect the lines established to each party to the call, 
and suffers the same drawbacks as U.S. Patent No. 6,188,683. Further no 
suggestion Is made to tiie modification of the biiiing technique proposed in the eariier 
U.S. patent. 
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international patent application publication No. WO 03/039181 discloses a 
technique which further improves on that disclosed in the two publications above. In 
this document there Is proposed enhanced techniques associated with conference 
calls. Connections between parties to any call are still established by a PSTN point 
5 of presence switch, using a conference bridge as is well-known in the art. There is 
no suggestion that billing of such calls Is anything other than conventional. 

Thus the techniques known in the art allow for calls to be established using 
Interfaces other than traditional dialling of a called number from a calling phone. 
Specifically the prior art generally allows calls to be established, for subscribers, 
10 using a website interface or an electronic text message. This does not. however, 
allow for all typical communication devices commonly in use to access the service. 

Furthermore, the techniques known in the art establish call connections using 
traditional telecorhmunlcation switches, typically a switch of a PSTN. Thus the 
provision of services in the prior art is associated with ail the technical disadvantages 
IS associated with traditional telecommunication switching. 

It is an aim of the present invention to provide an Improved technique for 
establishing a communication link between two points, which addresses one or more 
of the above-stated disadvantages. 

20 According to the present invention there is provided a method of establishing a 

communication between at least two end-points, comprising: receiving an Identifier of 
a calling number and an identifier of an action; establishing a communication link to 
the calling number; establishing a communication link in dependence on said action; 
and connecting the communication links in an IP domain. 

25 The step of connecting the communication links may be performed by controlling an 
IP routing device. The IP routing device may establish a PSTN connection to the 
calling number. 

The action may be to establish a telephone call to a called number, wherein 
the IP routing device establishes a PSTN connection to the called number and 
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connects the established PSTN connections to the caiiing number and the called 
number in the IP domain. The IP routing device may be controlled to establish the 
PSTN connections to the calling party and the called party at terminals thereof, the IP 
routing device being further adapted to connect said tenminals internally. 

5 The action may be to access a streamed service, wherein the IP routing 

device connects the PSTN connection to the streamed service in the IP domain. The 
IP routing device may be controlled to establish the PSTN connection to the caiiing 
party, the IP routing device being further adapted to route said PSTN connection to a 
mixing server adapted to receive the streamed sen^ice. 

10 The action may be to establish a PSTN connection to a plurality of called 

numbers, wherein the IP routing device connects the plurality of called numbers to 
the calling number in the IP domain. The IP routing device may be controlled to 
establish the PSTN connections to the calling party and the called parties at terminals 
thereof, the IP routing device being further adapted to route said connections to a 

15 mixing server in the IP domain. 

The step of receiving an identifier of a calling number may comprise identifying 
the originating number of a request for the action. The step of receiving an identifier, 
of a calling number may comprise extracting the calling number from a request for 
the action. The request may contain an identifier which maps to the calling number. 

20 The identifier of the action may comprise the called number, the method comprising 
extracting the called number from a request for the action. The request may contain 
an identifier which maps to the called number. 

The request message may be received from any one of an e-mail client, a web 
client, an SIVIS client, a SOAP/HTTP client, or a WAP client. 

25 The IP routing device is preferably controlled using SIP messages. 

The method may further comprise receiving a request to establish a call 
connection at a web server, said request Including the Identifier of the caiiing number 
and the identifier of the action; verifying said request at the web server; transmitting 
said request in XML message format to a call controller controlling an IP router using 
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SIP message, establishing the cx)mmunlcatlon link to the calling number at the IP 
router under the control of the call controller. 

The rhethod may further comprise establishing the communication link to the 
called number at the IP router under the control of the call controller, and controlling 
5 the IP router to connect the established communication links internally. 

The IP routing device may route said PSTN connection to a mixing server 
adapted to receive the streamed service. 

The method may further comprise establishing communication links to the 
called numbers at the IP router under the control of the call controller, and controlling 
10 the IP router to connect the established communication links to a mixer in the IP 
domain, and mixing the established communication links under the control of the call 
controller. 

In accordance with the present Invention there Is also provided a 
communication element adapted to establish a communication between at least two 
15 end-points, comprising: means adapted for receiving a request including an identifier 
of a calling number and an identifier of an action; means adapted for establishing a 
communication link to the calling number; means adapted for detemnining a 
communication link in dependence on said action; and means adapted for connecting 
the communication links in an IP domain. 

20 The request may be an XML message, the means adapted for establishing a 

communication link to the calling number and the means adapted for connecting the 
communication links in an IP domain preferably comprising control means for 
transmitting SIP messages to an IP router. 

If the action is to establish a call between a calling party and a called party, the 
25 SIP messages may instruct the IP router to establish a PSTN connection to each 
party and connect such connections internally. 

If the action is to establish a call between a calling party and multiple called 
parties, the SlP messages may instruct the IP router to establish a PSTN connection 
to each party and route such connections to a mixer in the IP domain. 
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If the action Is to establish a connection for the calling party to a streamed 
service, the SIP messages may Instmct the IP router to establish a PSTN connection 
to the calling party and route such connections to a mixer In the IP domain adapted to 
receive the streamed service. 

5 The element is preferably a switching server. 

In a further aspect the present invention provides a communication element 
adapted to control the establishment of a communication between at least two end- 
points, comprising: means adapted for receiving a request including an identifier* of a 
calling number and an identifier of an action; means adapted for verifying the request, 
10 and means adapted to transmit said request in XiVIL fomnat messages to an element 
for establishing the communication. 

The request may comprise a message from any one of an e-mail client, a web 
client, an SMS client, a SOAP/HTTP client, or a WAP client 

In a further aspect the present invention provides an IP router adapted to establish of 
15 a communication between at least two end-points, the router being adapted to 
establish a PSTN communication link to a first end-point, establish a communication 
link to a second end-point, and connect said established communications intemally. 

In a still further aspect the present invention provides a communication system 
adapted to esteiblishing a communication between at least two end-points, 

20 comprising: a control server for receiving a request including an identifier of a calling 
number of one end-point and an Identifier of an action, and adapted to transmit said 
request in XI\^L fonnat In dependence upon said action, a switching control server for 
receiving the request in XI\^L fonnat; an IP router operating under the control of SIP 
messages from the switching control server; the IP router being controlled for 

25 . establishing a first communication link to flie calling number of the one end-point; 
wherein the switching controller further controls the IP router to connect the 
established communication link to the other end-point. 

In a further aspect of the present invention, there is provided a controlling point 
of presence and a switching point of presence. In which requests for establishment of 
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communications are received at the controlling point of presence, and fonvarded to 
. the switching point of presence, the switching point of presence Including means for 
establishing any required communication connection, and means for connecting the 
required communication connection In the IP domain. 

5 In a further aspect, the present Invention provides a method of establishing a 

telephone connection. In which a subscriber provides a recipient telephone number, a 
message Is sent to the recipient telephone number, and responsive to receipt of a 
reply from the recipient telephone number a telephone call Is established from the 
recipient telephone number, the cost of the call being charged to the subscriber. The 

10 nriessage is preferably a SMS or text message. The call ls preferably a call to a 
number provided by the subscriber, preferably the subscribers number. The method 
is preferably supported by an application server. The application server is preferably 
associated with a plurality of identifiers used for the purpose of identifying the origin 
of the text message. The text message sent to the recipient preferably uses one of 

15 said plurality of identifiers. The text message sent to the recipient preferably includes 
a unique identifier. The unique identifier preferably comprises the combination of the 
recipient number and one of the identifiers used for the purpose of identifying the 
origin of the text message. The reply from the recipient is preferably directed to the 
application server In dependence on the one of the identifiers used for the purpose of 

20 Identifying the origin of the text message contained in the message sent to the 
redpient. The text message may Invite the recipient to participate In a conference 
call. The application server may be a web server. The subscriber preferably provides 
the recipient number by way of a text message, the text message constituting a 
request for initiation of a text message to the recipient. The establishment of the 

25 telephone connection may be associated with the system and/or method defined 
anywhere In the present description as a whole. The method may be initiated by e- 
maii or uri. 

In a further aspect there Is provided a method of billing for a telephone. call, in 
which the telephone call is established by establishing a first telephone connection 
30 from a switching point to a calling party, establishing a second telephone connection 
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from a switching point to a called party, and connecting the established telephone 
connections, wherein the cost of the call Is dependent upon the cost of making a 
telephone call from the switching point to the respective parties. The switching points 
are preferably the same point. The switching points may be distinct switching points, 
5 Interconnected, for example by an integrated backbone. Each switching point is 
preferably in a fixed geographical location. The cost of the call is based upon a first 
cost component being dependent upon the cost of a call from the geographical 
location of the switching point to the geographical location of the calling party, and a 
second cost component being dependent upon the cost of a call from the 

10 geographical location of the switching point and the geographical location of the 
called party. The first cost component may be adapted in dependence on the cost of 
making a telephone call from the geographical location of the calling party. The first 
cost component may be adapted In dependence on the cost of making a telephone 
call from the geographical location of the calling party to the switching point. The first 

IS cost component may be adapted in dependence on the cost of making a telephone 
call from the geographical location of the calling party to the geographical location of 
the called party. 

The present invention thus provides an apparatus and method for establishing 
fixed and mobile telephony using a layered architecture over a distributed network. 
20 This approach tightly meshes data networks, for call control, with the existing public 
switched telephone network (PSTN) for call completion. 

The system is designed to be independent of the source of user instructions. 
The initiation methods may be wide and varied, but are preferably not based on 
traditional telephony methods. User instructions are received at a controlling point of 
25 presence (POP). Control and data is consolidated at the controlling POP. A single 
controlling POP is provided in a preferred embodiment. Additional controlling POPs 
may be provided, being closely coupled for communication therebetween, for 
resilience (i.e. redundancy). 

All calls preferably originate over a central switching point of presence (POP), 
30 which interconnects with wholesale long-distance earners used for least cost routing. 
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In embodiments, multiple sNA^tchlng POPs may be provided, with each call being 
directed to the most appropriate POP In accordance with system configuration 
settings and requirements. 

In establishing a call between parties, each call consists of a minimum of two 
5 legs, one leg to the calling party and one leg to the called party. Thus the first leg is 
an inbound call to the usen and the second leg Is an outbound call to the calling 
destination. . Once both legs are in progress, they are connected to allow seamless 
communication. In such an implementation the parties constitute the end-points of 
the telephone connection. In a conference (n-way) call, multiple legs are established 
10 to connect multiple parties. 

The Invention may be further utilised to establish a connection between a party 
and a service provider, such as to allow a user to access music services, news 
services, voice mail services, etc. In such an implementation the calling party may be 
considered to be one end-point, and the service provider the other end-point. 

IS The system advantageously allows discrete users to Initiate and control voice 

communications independent of their local long-distance providers from any current 
location. Current modalities for call initiation advantageously include a web-page 
access, SMS messaging, a SOAP web service, e-maii access, and WAP services. 

20 The Invention will now be described in respect of a preferred embodiment with 

reference to the accompanying drawings, In which: 

Fig. 1 illustrates the system architecture of a preferred embodiment; 

25 Fig. 2 illustrates the steps for establishing a two-party call at a web sen/er In 

the architecture of Fig. 1 in accordance with the preferred embodiment; 



10 



Fig. 3 illustrates tlie steps for establishing a two-party call at a call control 
server in the architecture of Fig. 1 in accordance with the preferred embodiment. 

Fig. 4 illustrates In more detail the connection of a two-party call in the 
5 preferred system architecture of Fig. 1 ; 

Fig. 5 Illustrates the transmission of messages for establishing a two-party call 
in accordance with a preferred embodiment; 

10 Fig. 6 illustrates the steps for establishing a conference call at a web server in 

the architecture of Fig. 1 in accordance with the preferred embodiment; 

Fig. 7 illustrates the steps for establishing a conference call at a call control 
server in the architecture of Fig. 1 In accordance with the preferred embodiment; 

15 

Fig. 8 illustrates in more detail the connection of a conference call in the 
preferred system architecture of Fig. 1; and 

Fig. 9 illustrates the selection of costing for a call In accordance with a 
20 preferred embodiment. 

The invention is described herein by way of reference to a particular preferred 
environment. Such environment is presented only for the purpose of understanding 
the present invention. 

25 Referring to Fig. 1 , the infrastructure or system architecture 102 In accordance 

with a preferred embodiment of the present invention comprises a web server 1 06, a 




call controller or call control server 108, and a voice over IP (VoIP) router 110. The 
web server 106 is connected to a database or plurality of databases, represented by 
databases 116 and 118, via a communication link 160. The web server 106 Is 
connected to one or more clients, via Input devices, as represented by 
5 communication links 138, 140, 150, 192 and 148. 

The present invention Is not limited to any particular client or user Input device. 
Five different types of client or user input device are Illustrated In Rg. 1. The present 
invention may be Implemented with only one of such clients or user input devices. 
Furthemnore, the present invention may be Implemented with different types of clients 
10 or user input devices not shown in Fig. 1 . 

A first example client illustrated in Fig. 1 is an e-mail user 124. In order to 
interface the e-mail user 124 to the web server 106, a SMTP-HTTP adaptor 120 is 
provided. Thus a communication link 194 is provided between the e-mail user 124 
and the SMTP-HTTP adaptor 120, and a communication link 138 is provided 
15 between the SMTP-HTTP adaptor 1 20 and the web server 1 06. 

A second example client is a web user 126, which is connected directly to the 
web server 106 via communication link 140. 

A third example client Is an SMS user 128. The SMS user 128 is connected to 
an SMS gateway 136 via communication link 142. The SMS gateway is connected to 
20 an SMS proxy 122 via a communication link 144. The SMS proxy 122 is connected 
to the web server 106 via a communication link 150. 

A fourth example client is a SOAP HTTP application 130. The SOAP HTTP 
application 130 is connected to the web server 106 via a communication link 192. 

A fifth example client Is a WAP user 132. The WAP user 132 is connected to 
25 a WAP gateway 134 via a communication link 146. The WAP gateway 134 is 
connected to the web server 106 via a communication link 148. 

The operation of the various clients in accordance with a preferred 
embodiment of the invention, and their Interconnection with the infrastructure in 
accordance with the preferred embodiments of the invention, is described further 
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herelnbelow. In terms of the provision of clients, the SMTP to HTTP adaptor 120 and 
the SMS proxy 122 are provided as part of the system architecture 102 associated 
with the web server 106 in a prefen-ed embodiment of the present invention. Ail other 
Implementations associated vAVtx clients are provided by third parties. 

5 The web server 106 Is connected to the call controller 108 via a VPN tunnel 

114 across the internet 196 in the illustrative embodiment. Communication link 152 
represents the connection from the web server 106 to the VPN tunnel 114, and 
similarly communication link 154 represents connection from the call controller 108 to 
the VPN tunnel 114. 

10 It should be noted that the Interconnection of the web server 1 06 and the VoIP 

router 110 in Figure 1 Is illustrative of an embodiment, and other arrangements may 
exist. For example, the interconnection may be by way of a QoS (quality of service) 
assured Frame Relay Service over a Private Intranet supplier with a circuit to the call 
controller 108 from the interconnection 196. When multiple call controllers 108 are 

15 provided (see below), and different call controllers are used for different legs of a call, 
this technique may be used to guarantee the quality of the VoIP transports. 

in a further alternative the Interconnect 196 between the web server 106 and 
the call controller 108 may be an ISDN line, in embodiments different types of 
interconnection may be provided in parallel. For example, the ISDN line may be 
20 provided in parallel with the VPN tunnel an-angement of Figure 1 for back-up 
purposes. 

The call controller 108 is connected to the VoIP router 110 via communication 
link 156. The VoIP router 110 Is connected to a telephone switch 112 via 
communication link 158. The telephone switch 112 is in the public switched 
25 telephone network (PSTN) domain, in the embodiments shown, the telephone switch 
112 is In the domain of a PSTN 188. The telephone switch 112 is provided with a 
plurality of communication links generally illustrated by reference numeral 180, which 
connect to a plurality of carriers generally illustrated by 182. The communication 
links 180 and the earners 182 exist in the PSTN domain 188. 
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The web server 106, In conjunction with the databases 116 and 118, form the 
centralised user Interface of the prefenred architecture. On the other side of the VPN 
tunnel, the call controller 108 and the VoIP router 110 together forni the PSTN 
Interface 176, which more generally can be refen-ed to as a point of presence (POP) 
5 together with the PSTN switch 112. 

Thus the architecture of the present invention can generally be considered to 
consist of a controlling point of presence interconnected to a switching point of 
presence. In embodiments, as described further hereinbelow, both the switching and 
controlling points of presence may comprise multiple points of presence. 

10 . As mentioned. In further embodiments, there may be provided a plurality of 
PSTN interfaces, or switching POPs, as represented by PSTN interface 174 in Fig. 1. 
As can be seen in Rg. 1, PSTN interface 174 connects with the web server 106 via a 
further VPN tunnel 162. which has a communication linl< 164 to the web server 106 
and a communication link 166 to a further call controller 168. It should be noted that 

15 the elements 162, 164, 166 in Figure 1 are illustrative of the functionality of an 
embodiment of the invention. In effect, these elements are the same elements as 
elements 196, 152, 154, but connected to a different location, i.e. call controller 168. 
The call controller 168 Interfaces to a VoIP router 169 via a communication link 170, 
which in tum comrhunicates vAVn a further telephone switch 178 via a communication 

20 link 172. The telephone switch 178 is associated with a further PSTN domain 190, 
including a plurality of communication links 184 from the telephone switch 178 to a 
plurality of carriers 1 86. 

The operation of the infrastructure of Fig. 1 will be further described hereafter 
in detail. 

25 The principle of the operation of the infrastructure in accordance with the 

present Invention is for a client or user, preferably a client or user subscriber, to 
provide the web server 106 with a request detailing a telephone connection which is 
to be established. In a two-party call, this will be the Identity of a telephone number 
from which the call is to be established, and a telephone number to which the call is 
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to be established to. In a conference call, this will be a number from which the call is 
to be established, and a plurality of numbers to which the call Is to be established to. 
The details of the telephone connection to be established may be Inherent or explicit 
in the request, as is discussed further hereinbelow. 

5 The web server 106 then provides details of the parties to which the call is to 

be established to the call controller 108. which controls the VoIP router 110 to 
establish such calls. The VoIP router 110 establishes the call connections through 
the telephone switch 112. In a two-party call, the connection of the calls is made in 
the VoIP router 110. In a conference call, the connection of the parties is made In the 
10 call controller 108 via the VoIP router 110. 

The web sen/er 106 preferably supports the operation of the infrastructure In 
accordance with embodiments of the present invention. The databases 116 and 118 
preferably store details of registered subscribers to the service supported by the 
infrastructure. This may include information which can be used by the web server 
IS 106 to validate a request for supporting a call connection. 

Techniques for subscriber registration are well-loiown in the art, and one 
sidlled in the art will be familiar with the implementation of such techniques. On 
registering wth the service, as will be further described herein a subscriber preferably 
provides details of the telephone numbers with which they wish to utilise the service. 

20 This may be a home telephone number, a work telephone number, a mobile 
telephone number etc. In a preferred embodiment, an authentication procedure is 
provided as part of the registration process, in order to validate the telephone 
number. For example, as part of the registration process, using an on-line form 
presented on a screen of a computer, the new subscriber is required to enter the 

25 telephone number from which services are to be established. As part of an 
authentication procedure, once this form is submitted, the system telephones that 
number, and plays a recorded message requesting a PIN number to be entered in 
the l<eypad of the phone. The PIN number is simultaneously displayed on the 
computer screen, and the new subscriber reads the number off the screen and enters 

30 it into the Iceypad of the phone. Responsive to detection of the correct PIN number. 




the system validates the subscription process. This is a one-time event on 
subscription. This process may be repeated for every telephone number provided by 
a subscriber and which is to be used as a basis of service initiation. It may also be 
repeated whenever the subscriber wishes to add a new w . number to their 
5 subscription or remove a number from their subscription. 

On registration, as well as providing the telephone numbers which may be 
used for initiation or origination of the service, the user may provide telephone 
numbers to fomn their own directory, together with 'short codes* to simplify system 
* use. For example, a user may provide the numbers stored In theiur mobile phone 
10 memory, together with the names associated with such numbers. When a call is 
Initiated, as described belbw, rather than providing the actual number of the called 
party the subscriber may simply provide a name, or short-code. 

The registration process preferably tatces place through access to a website 
hosted by the web server 106. However the invention is not limited to this specific 
15 form of registration process, and other means for registration may be provided. 
Further once a subscriber is registered, the service itself may be accessed by any 
means of access, and is not limited. 

The access by clients or users to the web server 106, using one of the five 
described prefen-ed client interfaces, Is further described herelnbeiow. It should be 
20 noted that the purpose of the service is to provide establishment of a communication 
between at least two end-points, comprising establishment of at least one telephone 
call. In a preferred embodiment, the end-points are two parties to a telephone call. In 
alternative embodiments, one end-point may be a service provider, such as a music 
service provider, news service provider, or messaging service provider. 

25 The subscriber, or party requesting establishment of the call, may not 

necessarily make the request for establishment of a communication from a device 
from which they wish to mal<e the telephone call. Thus the client may provide a 
calling number and a called number (or service identifier) to the web server 106 
(explicit mode). The calling number is preferably a number provided by the subscriber 
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on registration. Alternatively, the client may simply provide the called number (or 
service Identifier), the calling , number being by default the number from which the 
request Is made (inherent mode). 

The request may not Include any numbers. For example if a caller makes a 
5 request using their mobile phone, but wants the call to be established using their 
home phone (the home phone number being the calling number), they may simply 
Include the command 'home* In the request. Similarly If the subscriber has 
established a directory with their subscription, rather than Including the called number 
In the request, they may include the associated short code, which may be the name 
10 of the person to be called, e.g. 'John'. 

As well as establishing calls to specific called numbers, the service may also 
be used to establish calls to services. In one embodiment, a subscriber can initiate 
public directory dialling of a call. For example, if a subscriber wishes to contact a 
particular organisation or service, but does no have that number, that can simply text 

15 the name of the organisation, which Is mapped to a number from a public directory. 
For example, the text message '\BM' may initiate a call to a general IBM enquiries 
number. The service may be adapted to introduce a location specific aspect. For 
example, based on the location of the origination number, the name may be mapped 
to a number for that organisation determined to be proximate to the location number. 

20 For example, a subscriber sending a request Identifying a company name and a 
calling phone number, e.g. home phone number, may be connected to the phone 
number for that company nearest to the subscriber's home, on the basis of area 
code. This may be quite general, e.g. based on country of origin, or more specific, 
e.g. based on town. This technique may be further refined such that a subscriber may 

25 Include details of a location in the request. For example, a text message may Include 
'IBM', followed by a postcode (ZIP code), name of a town or city, or part of a 
postcode or name. For example, if a subscriber is in the postal district SW1 in 
London, they may text the message 'Dominos SWr, and be connected to the local 
Dominos pizza outlet for SW1 . 




The service is preferabiy a subscriber service, and requests for use of tiie 
service are ttierefore made from ciients or users wliose subscription details are 
stored in the databases 116, 118. The subscription details may include credit details, 
e.g. if the user has a credit limit, or is a pre-paid or post-paid user. As discussed 
5 above, the subscription details may also include a store of numbers with tags, e.g. 
the subscribers home, wori< and mobile telephone numbers tagged with labels 
'home', 'wori<'. 'mobile'. In this way, as will be described hereinbeiow, the user may 
provide the web-server with a tag rather than a number. The database 116, 118 
may. In a similar manner, contain a subscriber phone directory with a tag for each 
10 number. 

Subscribers may register for the sen/ice In a number of ways. As known In the 
art, a subscriber may register via a website interface associated with the web server 
108. The subscription mechanism using a website will be familiar to one sicilled in the 
art. The website associated with the web server preferably has multi-lingual options 
15 and multi-time zone options so that the system operates in local language and time, 
and processes locally received messages based on local time. All subscriber records 
preferably show call records In local time and billing records in local currency. The 
access to the website may be indirect, for example through a local agent acting as a 
tirusted party between a subscriber and the web server 106 host. 

20 The preferred embodiments below are described in the context of a system operated 
by Caillcey, having a website address of www.callkev.com through which users may 
subscribe to Callkey services. 

In a preferred embodiment, the e-mail client or user 124 sends an e-mail to an 
address of the fomi 441 624823833(g>.cail.callkev.com . in an alternative, rather than 
25 ■ sending a number a short code may be sent of the format, for example, 
iohn(3>callkev.com . The short code 'john' could tiien be looked-up in tiie subscribers 
personal directory to find the specific number to call for 'john'. 

The e-mail may further be modified to define particular functions. For example: 

@billing.callkey.com may be used to obtain a cun-ent statement 
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@home.callkey.com may be used to utilise the subscribers default home 
origination number 

@work.callkey.com may be used to define the subscribers default woric 
origination number 

5 @mobiie.calll<ey.com may be used to define the subscribers default mobile 

origination number 

@sms.callkey.com may be used to send an SMS message rather than 
establish a call 

Regardless of its format, this e-mail is delivered from the client's workstation 
10 (or othei' e-mail tool) to the local mail server, which in turn users the DNS system to 
discover the IP address of the host processing mail for the call.cailkey.com domain 
by way of an MX record lookup. The MX record will direct the mall server to the IP 
address of the SMTP-tHTTP adaptor 120. The mail server then delivers the message 
using SMTP to the SMTP-HTTP adaptor 120. Such processing of an e-mail is well- 
15 known in the art. The message is then forwarded to the web server 106 using HTTP. 
The SMPT-HTTP adaptor 120 is preferably a Windows 2000 service which monitors 
port 25 and accepts the parses incoming mail messages according to the SMT 
protocol [RFC821] as known in the art. The service delivers the message to the web 
server 106 at a pre-configured URI using the HTTP protocol [RFC2616] as known in 
20 the art. 

The web server 106 preferably uses the "from" address extracted from the e- 
mail to identify the user, and thereafter checks the user subscriber status. 

In the case of a web user client 126, the client interfaces with the website 
associated with the web server 106. Upon connecting to the site, the system uses 
25 HTTP authentication to identify the user via a user name/password pair, which is 
checked in the databases 116, 118. The access of a web user client to a web server 
via a web interface is well-known in the art. 

in the case of an SMS user client 128, the SMS user sends an SMS message 
to the local SMS service centre, addressing the message to a predetermined 
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number. The message is routed to the SMS gateway 136 provider, which delivers 
the message to the SMS proxy server 122 within the Infrastructure 102 using a 
proprietary protocol. The SMS proxy server 122 then delivers the message using 
HTTP to the web server 1 06. 

5 In the example of a SOAP/HTTP application client 130, a SOAP-compllant 

application makes a request to the servers by interpreting a WSDL [W3C] resource, 
and forming a valid request containing the details of the request. This is delivered to 
the web server 106 over HTTP using communication link 192 according to the SOAP 
[W3C] convention. 

10 In the case of a WAP user client 132, the WAP user submits a request via a 

third party WAP gateway 134, which in turn forwards requests to the web server 106 
using HTTP. 

Regardless of the client user, the web server 106 interprets and processes 
Instructions received from the client device or gateway. The request from a client is 
IS for a call to be placed, modified or tennlnated. 

The request from the subscriber may, in one embodiment, simply identify the 
number to which the call is to be made. The number from which the call is to be 
made may be determined based on the source of the request, or by identifying the 
source of the request to a default number In the subscriber's record in the database. 
20 For example if the request is by SMS. the default calling number may be taken to be 
the subscriber's mobile number. If the request Is by e-mail, the default calling 
number may be the subscriber's home telephone number. In other embodlmente, the 
subscriber request may specifically Include the calling number, as described 
hereinabove. 

25 Responsive to a request, the web server 106 forms an XML description of the action, 
which Is fonwarded to the call controller 108 using HTTP via the VPN tunnel 114 in 
the described embodiment. The VPN tunnel 114 is a DES-encrypted VPN over the 
Internet, supported by fire walls. The structure of such a communication channel is 
understood by one skilled In the art. Typically, the web server 106 resides within the 



20 



IT hosting facility, and the call controller 108 resides In proximity to the telephony 
Infrastructure. As such, the web server 106 and the call controller 108 are typically 
geographically separated. As such HTTP is used since It uses TCP. a connecHon 
based, Inherently reliable transport interface. 

Contained within the XiVIL description is a caii-back URL. The call controller 
108 uses this URL to send back status infomnation to the web server 106 whenever 
there Is a change to a call or one or more of the calls constituent legs, or to 
acknowledge messages. Thus the URL effectively provides an address for the call 
controller 108 to correspond with. 

The call controller 108 communicates with one or more voice over IP routers, 
such as VoIP router 110. using a session Initiation protocol (SIP) [RFC2543] in 
combination v^th the SDP protocol [RFC2327]. The SIP messages (with SDP 
payioads where appropriate) are sent over TCP to the VoIP router 110. -The VoIP 
router replies with SIP response messages. These messages are refomiatted by the 
call controller 108 as XIVIL messages, and fonwarded to the web server 106 as 
described above. 

The establishment of messages using XML and SIP are known in the art. and 
the Implementation of an interface in the call controller 108 to convert XML messages 
to SIP messages and vice versa will be within the scope of one skilled in the art. 

The VoIP router 110 may also generate ad-hoc messages In response to 
particular events (for example, a call party hanging up). The call controller 108 
converts and fonwards these messages to the web server 106 in the same way. 

In the prefen-ed embodiment, the VoIP router 110 communicates with flie 
telephone switch 112 using QSIG-PRI signalling as known in the art. 

As noted, the VoIP router 110 may be one of a plurality of such routers 
controlled by the call controller 108. The provision of more than one VoIP router is 
an implementation issue associated with the capacity of the system. 

As discussed hereinabove, the web-server 106 may be able to direct requests 
to more than one call controller, such as call controllers 108. 168. The call controller 
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to which a request is directed may be based upon current usage of each controller. 
Queuing techniques may be used, the Implementation of which are outside the scope 
of the present invention. 

The l<ey to the operation of the infrastructure in accordance with embodiments 
5 of the preferred invention is the correct sequencing of communication between 
layers. This is further illustrated hereinbeiow by way of reference to detailed 
operation. 

Referring to Figs. 2 and 3, in conjunction with Fig. 1, there is illustrated the 
establishment of a two party call in accordance with a preferred embodiment of the 
10 present invention. 

Fig. 2 illustrates the process followed in the web server 106. Refening to Fig. 
2, In a step 202 the web server 106 receives an instruction from a subscriber, Which 
Instruction may be received from any one of the plurality of client/user interface 
means. In a step 204, the web server then accesses the subscriber details in the 
IS databases 116, 118, and malces any necessary checks to ensure the service Is 
available to the subscriber. Thereafter, the web server 106 processes the request 
made by the subscriber. 

In a step 206, it is determined whether the subscriber is requesting the 
establishment of a call. If the subscriber is requesting establishment of a call, in a 
20 step 210 the web server 106 creates a call establishment message In XML format, . 
and then in a step 212 transmits such message to the call controller 208 via the VPN 
tunnel 114. 

In a step 214, the web server 106 monitors for receipt of a. message from the 
call controller 108 confirming that the call has been established. If no such message 
25 is received within a particular time period, then the web server may revert to step 212 
and retransmit the message to the call controller 108. If after a certain number of 
retransmissions there is still not received a message confirming establishment of the 
call, then the attempt to establish the call may be abandoned. 
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If it is detected in step 214 that the call controller 108 has confirmed 
establishment of a call, then In a step 216 the web server 106 commences billing for 
the call. This may Include updating the details In the databases 116, 118 for the 
subscriber to show a start time for the call, and recording therewith the calling and 
5 called numbers, the charge rate, and cunrent call cost. 

Thereafter in step 218. the web server 106 monitors for a message from the 
call controller 108 that the call has been terminated. On receipt of a message from 
the call controller 108 that the call is now temninated, in a step 226 the web server 
106 tenninates the billing. The subscriber's account is then modified in step 228. 

10 The modification of the account may include adding an end time to the infonnation 
associated with the call, and calculating a cost for the call in accordance with the 
preferred embodiment, as described hereinbelow with reference to Fig. 9. In a 
preferred embodiment, in a step 230 the subscriber is then notified by the web server 
106 of tfie cost of the call. This may, for example, be by way of SI\4S message to the 

15 subscriber. 

The billing of the call to the subscriber may be In accordance with any 
conventional billing method. For example a monthly Invoice, automatic debiting from 
a banic account or credit card, deduction of credit. 

It Is further possible for the calling party to terminate the call by request to the 
20 web server 106. On receipt of an instruction, the web server as shown in Rg. 2 first 
establishes whether the instruction is to establish a call In step 206. If the instruction 

is not to establish a call, then in step 208 It is determined whether the instruction is to 
tenninate a call. If the instruction is to terminate a call, then in step 220 a message to 
tenninate the call is created, and then in step 222 such message is transmitted to the 
25 call controller 108. In step 224 the web server 106 monitors to determine whether 
the call controller 108 acknowledges the message to temninate the call. If such 
message is not acknowledged within a certain time period, then the procedure 
reverts to step 222 and the temninate message is retransmitted. On receipt of 
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confirmation of termination of the call in step 224, the steps 226, 228 and 230 are 
repeated as described hereinabove. 

Thus, with reference to Fig. 2 there is described a preferred implementation of 
a process for establishing and temiinating a two-party call at the web server 106 in a 
5 preferred system architecture. 

Refening to Fig. 3, there Is now described a preferred implementation for 
establishing and terminating a two-party call at the call controller or call control server 
108 in accordance with a preferred embodiment of the present invention, 
complimentary to the web server process of Fig. 2, 

10 In a step 302, the call controller 108 receives a message from the web server 

106. in a step 304, the call controller 108 then determines whether the request Is an 
Instruction to establish a call. If the instruction is to establish a call, then in a step 
306 the call controller lOiS establishes a first leg of the call, termed "leg A", which is 
preferably to the calling party. This leg Is established by the call controller 108 

15 Instmctlng the VoIP router 110. 

Thereafter, in a step 308. the second leg of the call is established, termed "leg 
B", preferably being the leg of the call to the called party. The call is established by 
the VoIP router 110 under control of the call controller 108. 

After establishment of the two legs, in a step 310 the call controller 108 
20 Instructs the VoIP router 110 to connect the two legs of the call together. The two 
legs of the call are connected together internally in the VoIP router 110. 

In this respect, reference is now made to Fig. 4. 

Refem'ng to Fig. 4, it can be seen that the VoIP router 110 establishes a call 
from node 408 to the telephone svy^tch 112 via llnic 404, and establishes a call from 
25 node 406 to the telephone switch 1 12 via linl< 402. This corresponds to leg A and leg 
B. The telephone switch 112 connects each of the calls on links 404 and 402 to the 
respective ones of the calling party and the qalled party via the PSTN. The VoIP 
router 1 10 in addition intemally connects the nodes 408 and 406 as illustrated by the 
dash line 41 0. 
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The VoIP router Is thus used to connect the legs of the call In the IP domain. 
The request for the calls from the VoIP router 110 to the telephone switch 112 Is via 
T1 connections on the communication links 158, as known In the art. which are PRI 
Interfaces. The two legs of the call are collated Intemal to the VoIP router 110. 

5 Thus the two legs of the call are connected In the IP domain with IP routing 

under control of an SIP session. 

This Is advantageous over the traditional use of a telecommunication switch 
for connecting the calls such as In the prior art discussed In the Background to the 
Invention. When a VoIP router is used to pre-establish the calls and then Instruct the 

10 onward switch to only place the calls but not blend them, the calls themselves are not 
confined to the PSTN environment. As such, they can be routed to completely 
physically and geographically distinct locations by virtue of the fact that they are 
encapsulated as VoIP before the process starts. The use of SIP and a method for 
starting the call within the router also means that even more dispersion can happen 

15 as a result of physically and geographically distinct routers being used in the first 
place. In essence, each call has Its own VoIP Identity and can ghave Its own routint 
path. 

The use of the VoIP router also offers the advantage of a non-proprietary 
implementation. The use of of IP routers allows the onward connection to be open, as 
20 it uses standardised Q.931 PRI signalling. 

After connection of the two legs of the call, In a further step 312 a message 
Indicating establishment of the call is transmitted to the web server 106. 
In a step 314, the call controller 108 then monitors each of the legs of the two party 
call. If in step 316 It Is detemnlned that a leg Is temilnated. then In a two-party call 
25 this represents termination of the entire call. If no leg Is terminated, then In step 314 
the status of each leg continues to be monitored. 

In the event that termination of a leg is detected in step 316, then in step 318 
the call controller 108 controls the VoIP router 110 to temiinate the other leg. 
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Thereafter, in a step 320 the call controller 108 transmits a message to the web 
server 106 to confirm termination of the call. In a step 322 the call controller 108 
monitors for aclcnowledgement of such message, and If no such acl<nowledgement is 
received reverts to step 320 and retransmits the temilnation message. On detection 
5 of receipt of the acl<nowledgement in step 322, in step 324 the call controller process 
temninates. 

As discussed hereinabove in relation to Fig. 2. a call may also be terminated 
on instruction from the web server 106, responsive to a request fi-om the subscriber. 
Thus the call controller 108 may in addition to receiving an instruction to establish a 
10 call, also receive an instruction to tenninate a call. If In step 304 it Is detemnined that 
the received instmction is not to establish a call, then in step 326 it Is determined 
whether the instruction is to .temiinate a call. 

If in step 326 it is determined that the instruction is to terminate a call, then in 
step 328 the call controller 108 controls the VoIP router 1 10 to temninate both legs of 
15 the call. Thereafter, steps 320, 322 and 324 are repeated. 

If in step 326 it Is detemiined that the instruction is not to tenninate a call, then 
tiie call conti'olier 108 may simply return to step 302 to monitor for received 
messages. In embodiments, Vne call controller may be able to process furUier 
different types of request firom the web server 106, such as requests associated with 
20 conference calls as described further hereinbelow. 

As noted above, in the preferred embodiment ail signalling between the web 
server 106 and the call controller 108 is by XML messages. All signalling between 
the call controller 108 and the VoIP router 110 is via SIP messages. 

A more detailed description of the messaging between the web server 106, the 
25 call controller 108, and the VoIP router 110 in accordance witti a prefenred 
embodiment of the invention is now described with reference to Fig. 5. in Fig, 5, it is 
assumed that the call controller 108 interfaces with a plurality of VoIP routers 110, 
and the first leg of the call is created via one VoIP router 1 10a, and the second leg of 
the call is created via a furtiier VoIP router 110b. Whilst such implementation is 
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possible, the preferred Implementation Is that all legs of a call are established via the 
same VoIP router. 

The preferred Implementation described with Fig. 5 illustrates the use of XML 
messages between the web server 106 and the call controller 108, and SIP 

5 messages between the call controller 1 08 and VoIP router 110. 

The web server 106 transmits a place call request message 502 to the call 
controller 108. Responsive thereto, the call controller 108 transmits an Invite 
(delayed media) message 504 to the VoIP router 110a. The VoIP router 110a 
returns a 100 trying message 506 to the call controller 108, which In turn transmits an 

10 accepted message 508 to the web server 106. Thereafter the VoIP router 110a 
returns a 183 session progress (with SDP1) message 510 to the call controller 108. 
which in turn transmits a ringing message 512 to the web server 106. Thereafter the 
VoIP router 110a sends a 200 OK (with SDP1) message 514 to the call controller 
108. which in turn sends an answered message 516 to the web server 106. At this 

15 stage, the first leg of the call session has been established. 

The call controller 108 then sends an Invite (with SDP1) message 518 to the 
VoIP router 110b. VoIP router 110b returns a 100 trying message 520 to the call 
controller 108. which In tum returns an accepted message 522 to the web server 106. 
The VoIP router 110b then returns a 183 session progress (with SDP2) message 524 

20 to the call controller 108. which In tum returns a ringing message 526 to the web 
server 106. 

In the prefen-ed embodiment, at this stage the call controller 108 then forwards 
an acknowledged message ACK (with SDP2) 528 to the VoIP router 110a to 
acknowledge set up of the first leg of the call. The VoIP router 110b then retums a 
25 200 OK (with SDP2) message 530 to the call controller 108. which in tum retums an 
answered message 532 to the web server 106. After returning the answered 
message 532. the call controller 108 retums a joined message 534 to the web server 
106 to indicate joining of the two legs of the telephone call, and then forwards an 
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acknowledged message 536 to the VoIP router 110b to complete the set up of the 
second leg of the call. 

Thereafter, a conversation between the two parties takes place as generally 
indicated by reference numeral 538. 

In normal operation, the call is terminated by one party "hanging up". The 
party established via VoIP router 110a hangs up, and as such a BYE message 540 is 
transmitted from the VoIP router 110a to the call controller 108. In turn the call 
controller 108 transmits a hung up message 542 to the web server 106. The call 
controller 108 then transmits a BYE message 544 to the VoIP router 1 10b, and a 200 
OK message 546 to the VoIP router 110a. The VoIP router 110b then transmits a 
200 OK message 548 to the call controller 108, and the session is thus temiinated. 

Fig. 5 Illustrates the preferred sequencing of communication between layers of 
the infrastructure for the XML and SIP Implementation. The correct sequencing of 
the messages is key to optimising the Implementation. 

The system infrastructure of the present invention advantageously enables for 
the implementation of reverse billing for callers who are not subscribers to the 
service. In order to enable this, a function is preferably utilised, where a subscriber 
sends an SIVIS request asking a person, who may not be a subscriber, to call them 
back by replying to the message. A combination of the recipient's number and one of 
a pool of MSIDN numbers used to send out the message from the SIVIS service 
centre identifies the returning message back to the original sender and the call is 
established with the billing running In reverse, with the subscriber paying for the call. 
This Is essentially SMS initiated toll-free dialling. This feature establishes a principle 
by which It is possible to have two way Identified SMS messaging through a third 
party. A preferred implementation of such feature Is described In further detail 
hereinafter. 

In a preferred embodiment of this function, a subscriber accesses and logs 
into the web page hosted by the web server 106 and provided by the service 
provider. The appropriate function . option on the website is selected, and the 
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subscriber is prompted to enter certain Infonnatlon. Such Information may preferably 
Include: the recipient number (I.e. the number of the person to which toll-free or 
reverse charge calling Is to be provided): the number to which the eventual call 
should be connected (I.e. the called number for the recipient), typically the 

5 subscriber's number; and an expiry date or total number of usages. In one 
embodiment the recipient will be able to make the toll-free calls for a certain time 
window (hours, days, week. etc.). In another embodiment the recipient will be able to 
make toll-free calls on a certain number of occasions, e.g. as a one-off. It should be 
noted that the calls are toll-free to the recipient, but charged to the subscriber. It 

10 should also be noted that the recipient may only avail of this service in respect of the 
particular number provided by the subscriber who will be charged, in other 
embodiments. It Is envisaged that the subscriber may provide a plurality of numbers 
to which the recipient has. from their perspective, toll-free access. The subscriber 
may also enter text which is to be forward to ttie recipient, e.g. 'you on call me toll- 

15 free by replying to this message'. 

Following such activation of the fucntion by a subscriber, and entiy of tiie 
relevant details, the web server 106 allocates an outgoing SMS service number for 
ttie service. In a prefen-ed embodiment, the web server is provided witii a pool of 
numbers to use as SMS outgoing service numbers (MSIDNs), for example 50. The 

20 web server then selects one of such numbers for use with a particular session. The 
number of numbers In ttie pool may be implementation dependent, and the aim is to 
provide enough such tiiat ttie outgoing service message number for a particular 
session, togettier wltti ttie recipient number, fonn a unique combination. As will be 
apparent from the following, a unique Identifier is essential. Other means for 

25 providing unique identification may be used. 

This selected MSIDN and recipient number is stored togetiier witti ttie ottier 
details provided by the subscriber in a call record. 

The web server 106 ttien Initiates a text message to the recipient, using tiie 
recipient's number. The text message will originate from a number being the outgoing 

30 SMS service number allocated to the session. The text message includes ttie text 
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provided by the subscriber. This text message Is sent to the recipient in the nomnal 
way, through an SMS service centre (Text Gateway - not shown in Figure 1) to which 
the web server 106 is connected via the SIVIS proxy 122. The SIVIS proxy 122 
instructs the SIVIS service centre as to the (VISION which should be used for sending 
a particular message. The control of the i\/ISiDN of a text message in such a way is 
icnown in the art. 

On receipt of the t^ message, the recipient reads the message and replies 
with a bianl( message. The recipient need only select the reply option when reading 
the message, and need not enter any text. 

This reply message is therefore sent from the recipient to the Siy/IS service 
number for the session, I.e. the MSIDN associated with the message received by the 
recipient. This message is received at the SMS service centre and routed to the SMS 
proxy 122. The message received by the SMS proxy 106 includes the number from 
which it was sent (the recipient number), and the MSIDN to which it was sent. 

The web server then receives the message by interrogating the SMS proxy 
122, and extracts the sender number and the MSIDN to compare it with the recipient 
number and MSIDN pairs stored in the database 116,118, and retrieve the details of 
the session. Thereafter the web server 106 preferably initiates establishment of a call 
in accordance with the techniques , described in above. In this arrangement, the 
calling party is the recipient, and the leg A is established toward the calling party. The 
called party Is the subscriber, or a destination number nominated by the subscriber 
and the leg B is established toward the subscriber. However, the B-leg party, i.e. the 
subscriber, is billed. 

The described technique may also be used for recipients Identified by the 
subscriber by an e-mail address or uri address. The web sen/er sends a message to 
the stated address, and the recipient returns a reply including the telephone number 
which may be used for establishing calls. 

In the above described embodiments, with reference to Figs. 2 to 5, there has 
been described the implementation of the present invention in an example where a 
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two party call is established. The principles of the present Invention may also be 
used advantageously to establish a multi-party call. I.e. a conference call. The 
establishment of a conference call In accordance with a prefen-ed embodiment of the 
Invention is now described with reference to Fig. 6, 7 and 8. 

5 Referring to Fig. 6, as described hereinabove with reference to Fig. 2 in a step 

602 the web server 106 receives an instruction from a subscriber, in a step 604. 
using the databases 116, 118 the web sen/er 106 accesses and checks the 
necessary subscriber details before further processing the request. 

In a step 606. it is detemiined by the web sender 106 whether the request 

10 relates to an Instmction to establish a conference call. If the Instmctlon Is to establish 
a conference call, then in a step 610 the web server 106 creates a conference call 
establishment message, and then in step 612 transmits such message to the call 
controller 108. 

In step 614, it is detemnined whether the call controller 108 has responded to 
15 the web server 106 with a confirmation message that the conference call has been 
established. If not. then the transmission of the message In step 612 may be 
repeated. If after a predetemilned number of transmissions the call Is not 
established, then the attempt to establish the conference call may be terminated. 

If in step 614 it is determined that the conference call has been established, 
20 then in a step 616 the web server 106 identifies the legs of the call that have been 
established. Preferably, the call controller 108 provides the web server 106 with' an 
identity of the legs of the call established, in case one or more of the plurality of legs 
desired are not established. In a step 618 the web sender 106 can commence billing 
for the conference call in dependence on those legs established. 
25 In a step 620, the web sender 106 then monitors for detection of a message 

from the call controller 108 advising that a leg of the conference call has been 
terminated, if a leg is temiinated. then in a step 622, the web server determines 
whether the number of legs remaining in the conference call is greater than or equal 
to 2. If the number of legs is greater than or equal to 2, then the conference call is 
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not to be terminated. In a step 624, the web server 106 therefore modifies the billing 
of the conf^enoe call, to adjust for the tenninated leg, and then returns to step 620 to 
monitor for messages notifying leg termination. 

If in step 622 the number of legs remaining is detenmined to be not greater 
than or equal to 2, then there are not sufficient legs established to support a 
telephone call. Therefore in step 634 the web server 106 tenminates the billing, In 
step 636 the web server modifies the subscriber's account, and then In step 638 
notifies the subscriber. Steps 634, 636, 638 correspond to steps 226. 228. 230 
respectively of Fig. 2. 

In accordance with a preferred embodiment of the present invention, a 
subscriber is In addition able to modify a conference call after it is established. The 
modification may be to terminate the conference call, to add a call to the conference 
call, or delete a call from the conference call. As shown in Fig. 6, If it is detemained jn 
step 606 that the instruction received from a subscriber is not to establish a 
conference call, then in step 608 it is determined whether the instruction is to modify 
a conference call. 

If the Instruction Is to modify a conference call, ttien in step 626 it is 
determined whether the instruction Is to temnlnate the conference call. If so, then in 
step 628 a conference call termination message Is created, and in step 630 such 
message is transmitted to the call controller 108. In step 632 it Is detemiined 
whether an acknowledgement is received from the call controller. If not, the process 
reverts to step 630 and the message is re-transmitted. 

On confirmation of termination of the conference call In step 632, the process 
moves on to step 634, and the step 634, 636 and 638 are peri'onned as described 
hereinabove. 

If In step 626 It Is determined that the instruction received is not to terminate 
the conference call, then In step 640 it is determined whether the instruction is to 
delete a leg of the conference call. If so, then in step 642 a temnlnate leg message is 
created and transmitted to the call controller 108 in step 644. in step 646 receipt of 



32 



an acknowledgement of such message from the call controller Is monitored. If no 
acknowledgement Is received, the process reverts to step 644 and the message Is 
re-transmitted. If an acknowledgement Is received, then the process moves on to 
step 624 as described hereinabove. 

5 If In step 640 it Is detennined whether the message received is not to delete a 

leg. then In step 650 It Is determined whether the instruction is to add a leg. In such 
case, In step 652 an additional message is created, and transmitted to the call 
controller In step 654. In step 656 monitoring Is earned out for acknowledgement 
message from the call controller that the additional leg has been added. If no 

10 acknowledgement Is received, the process reverts to step 654 and the message Is 
re-transmitted. On receipt of an acknowledgement of the addition of the leg. the 
process moves on to step 624 and billing is modified as described hereinabove, with 
the addition of a leg. 

In Fig-. 6 there has been described the implementation of the procedures of the 

15 web server in relation to a preferred establishment and modification of a conference 
call. Referring to Fig. 7, the equivalent procedures implemented in the call controller 
108 are described. 

In a step 702. the call controller 108 receives a message request firom the web 
server. In step 704. it is determined whether such message Is an Instruction to 
20 establish a conference call. 

If the message is an instruction to establish a conference call, then in step 706 
the number of legs to be established is set equal to N. and a variable i is set to 1 . In 
a step 708. leg i Is then established. In a step 710. it is then determined whether i is 
equal to N. If I is not equal to N, then In a step 712 I Is incremented, and then In a 
25 step 708 leg I Is established. Thus the steps 708. 710. and 712 are repeated until 1 is 
equal to N. i.e. until all legs of the call are established. 

Preferably, an error detector Is built in to step 708, in the eventuality that it is 
not possible to establish a particular leg. In such eventuality, the process moves on 
to steps 710 and 712, and a log Is made of the failure to establish a particular leg. 
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After all legs are established In 710, or all legs with the exception of those In 
error are established. In step 714 the call controller 108 Instructs the VoIP router 110 
to connect the N legs. Refening to Fig. 8, the connection of the N legs In order to 
implement a conference call In accordance with a preferred embodiment of the 
5 present invention Is Illustrated. As can be seen in the example of Fig. 8. the legs of 
the call in an example where N = 4 are established between the VoIP router 1 10 and 
the telephone switch 112 on respective connections 808a-808d. Within the VoIP 
router 110, the connections 808a-808d are connected from one side of the router to 
the other side of the router via respective connections 806a'-806d, such that the 

10 connections are presented on the side of the VoIP router which connects to the call 
controller 108. The call connections are then connected to the call controller 108 via 
connections 804a-804d. The call controller then Intemaily connects the connections 
on lines 804a-804d to a mixer block 802, and mixes the four call connections. 
Although only four call connections are shown In Fig. 8, for a conference call 'the 

IS number of calls may be three or more, the limitations of the implementation only 
being due to the provision of resources In terms of the numbers of VoIP routers and 
connections available, or telephone switches available. 

On establishment of the conference call, in step 716 the call controller 108 
transmits a message to the web server 106, to confimn establishment. This message 
20 preferably conflmis the identity of the established legs to the web server 106. 

In a step 718, the call controller 108 monitors the status of the various legs. If 
In a step 720 a leg is temilnated, then In a step 722 a message is transmitted to the 
web server 106, identifying the temiinated leg. Othenwise, after step 720 the process 
reverts to step 718. 

25 After termination of a leg and transmission of the message in step 722, in a 

step 724 it Is detemrilned whether the number of legs remaining is greater than equal 
to 2. If this condition is satisfied, then the process returns to step 718. If tiiere are 
not greater or equal to 2 legs remaining, then in a step 726 all legs are terminated 
and in a step 728 the web server 106 is notified of the termination of all legs. 
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If In step 704 It is determined that the message received Is not an instruction to 
establish a conference call, It Is determined whether It is an Instmctlon to tenminate a 
conference call In step 730. If the instruction Is to tennlnate a conference call, then In 
step 732 all legs are terminated, and In step 734 conflnnation of the temiination of all 
S legs Is transmitted to the web server 1 06. 

If In step 730 it is determined that the instruction Is not to terminate a 
conference call, then in step 736 it Is detemnined whether the instmctlon is to delete a 
leg of the conference call, if the Instruction is to delete a leg of the conference call, 
then In step 738 the appropriate teg is terminated, and then In step 740 the web 
10 server is notified. 

If In step 736 It is determined that the instruction .Is not to delete a leg, then in 
step 742 it Is detemilned whether the Instruction is to add a leg. If the Instruction is to 
add a leg. then In step 744 the appropriate leg is established, in step 746 the call 
controller 108 Instructs the VoIP router 110 to connect the leg to the conference call, 
15 and then In step 748 the call controller 1 08 notifies the web server 1 06 appropriately. 

Whilst the establishment and control of a conference call has been described 
herein separate to establishment and control of a two-way call. It will be understood 
by one skilled in the art that they may be combined, in particular a two-way call may 
become a conference call (i.e. an n-way call) and a conference call (n-way call) may 
20 become a two-way call. As has also been described herein, a call may be established 
to a service provider rather than another party, which may be considered to be a one- 
way call, in a similar manner, a one-way call may be come a two-way or n-way call. 

Further, a user may be Invited to become a party to a conference ail by way of 
an SiVIS message, using the technique described hereinabove for toil-free telephone 
25 usage at the expense of the subscriber or Initiator of the conference call. 

The principles of operation of the architecture of a system in accordance with 
a preferred embodiment of the present invention having been described, the 
principles of call billing In a preferred embodiment are now described. 
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Referring to Fig. 9 there is illustrated the billing principle of calls established in 
accordance with the architecture of Fig. 1 . 

For a two-party call, the call cost is based on a cost associated with the first 
leg (leg A) and a cost associated with the second leg (leg B). In a preferred 
embodiment, the call controller 108 and V6IP router 110 are located at a single point, 
In a preferred implementation in New Yori<.' As such, the two legs of the call for a 
two-way call are established based on call made from New Yorlc. Thus the calling 
party Is called from New Yorl< and the called party is called from New York. The cost 
of the call to the called party, leg B, is based on the fixed cost of a call to that territory 
from New York. Such fixed costs may vary from time to time to take Into account 
variations in costs, Including variations in competitor costs. 

The cost of the call to the calling party, leg A. can be considered to be the cost, 
of making a call from a particular territory. This cost is not based on the cost of, 
making a call from New York to that territory, but rather a cost which is based on 
competitor costs of making a call from that territory. This cost may again vary In 
accordance with competitor variation In charges. 

Thus,: by establishing both calls of a two-way party call from a geographical 
location which ensures low cost calls, a call can be established at a low cost, relative 
to making such a call directly from the country of origin of the call. 

Fig. 9 effectively illustrates the charging table stored in the charging database 
for charging calls established in accordance with the inventive Infrastructure. 
However such charging techniques may also be applied to other infrastructures, and 
are not limited to being specifically applied in the infrastructure described 
hereinabove. 

As shown in Fig. 9, the charging table comprises three columns, a column 902 
listing all territories from which calls can be made or to which calls can be made to, a 
column 904 listing the call cost of making a call to a territory (i.e. the cost of leg B), 
and a column 906 listing the call cost of making a call from a territory (i.e. the cost of 
leg A). Thus for each territory,, there is defined two costs, the cost of making a call 
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from, and the cost of making a call to. Typically the costs are per minute or per 
second charges. Considering an example where a subscriber using the above 
described Infrastructure and being resident In Chile, wishes to place a telephone call 
to a party based In Greece. In accordance with the present Invention as described 

5 hereinabove, a call is established from the call controller In New Yoric to Chile (leg A), 
and a call Is established from the call controller In New York to Greece (leg B). The 
cost of the call is therefore based at a rate of CLa for leg A. and GRb for leg B. The 
minimum cost of leg A Is the cost of making a call from New York to Chile. In 
practice, competitor services for establishing long-distance calls from Chile will be 

10 significantly more expensive than this, and therefore the cost of the leg A call Is 
Increased so as to be In the region of competitive call charges, but still being the 
cheapest of the available charges. The cost of leg B Is simply the cost of placing a 
call from New York to Greece. 

In embodiments, multiple call controller and VoIP router combinations 176 

15 may be provided at multiple locations, and requests from the web server address to 
appropriate ones of such according to predetennined configurations. Multiple call 
controller and VoIP router combinations 176 may be connected via a common 
backt>one. 

The web server 106 Is preferably located In a different geographical site to that 
20 of the call controller and VoIP router combinations 1 76. 

The present invention has been described hereinabove with reference to 
particular prefen-ed embodiments. One skilled in the art will appreciate that the 
Invention is hot limited to such embodiments, and variations may exist. The scope of 
protection afforded by the invention is defined by the appended claims. 
25 Various abbreviations of well-known terminology are described herein. For the 

avoidance of doubt, a glossary of such temilnology Is provided below: 



Glossary of Terms 
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SOAP - Simple Object Access Protocol 

VPN . - Virtual Private Network 

HTTP - Hyper Text Transfer Protocol 

SMTP - Simple Mail Transfer Protocol 

S SMS - Short Messaging Service 

WAP - Wireless Application Program 

PSTN - Public Switched Telephone Networl< 

POP - Point of Presence 

MX record - Mall Exchange Record 

10 WSDL - Web Services Description Language 

XML - Extended Mari<-up Language 

• SIP - Session Initiation Protocol 

DES " Data Encryption Standard 

* TCP - Transport Control Protocol 

15 URL - Unifomi Resource Locator 

SDP - Session Description Protocol 

QSIG-PRI - Q Signalling Protocol over ISDN PRl Interi'ace 

PRI - Primary Rate Interface 
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Claims 

1. A method of establishing a communication between at least two end-points, 
comprising: receiving an identifier of a calling number and an identifier of an 
action; establishing a communication link to the calling number establishing a 

5 communication link In dependence on said- action; and connecting the 
communication links In an IP domain. 

2. A method according to claim 1 wherein the step of connecting the communication 
links is performed by controlling an IP routing device. 

3. A method according to claim 2 wherein the IP routing device may establish a 
10 PSTN connection to the calling number. 

4. A method according to claim 3 wherein the action is to establish a telephone call 
to a called number, wherein the IP routing device establishes a PSTN connection 
to tiie called number and connects ttie established PSTN connections to tiie 
calling number and the called number In the IP domain. 

15 5. A method according to claim 4 wherein the IP routing device is controlled to 
establish tiie PSTN connections to the calling party and tiie called party at 
temiinals tiiereof, the IP routing device being further adapted to connect said 
terminals Intemally. 

6. A method according to claim 3 wherein the action is to access a streamed 
20 service, wherein the IP routing device connects tiie PSTN connection to tiie 

streamed service in the IP domain. 

7. A method according to claim 6 wherein tiie IP routing device is controlled to 
establish tiie PSTN connection to tiie calling party, tiie IP routing device being 
further adapted to route said PSTN connection to a mbcing server adapted to 

25 receive the streamed service. 

8. A method according to claim 3 wherein the action is to establish a PSTN 
connection to a plurality of called numbers, wherein tiie IP routing device 
connects tiie plurality of called numbers to tiie calling number in the IP domain. 
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9. A method according to claim 8 wherein the IP routing device Is controlled to 
establish the PSTN connections to the calling party and the called parties at 
terminals thereof, the IP routing device being further adapted to route said 
connections to a mixing server in the IP domain. 

10. A method according to any preceding claim wherein the step of receiving an 
identifier of a calling number comprises identifying the originating number of a 
request for the action. 

11. A method according to any preceding claim wherein step of receiving an identifier 
of a calling number comprises extracting the calling number from a request for the 
action. 

12. A method according to claim 12 request may contain an identifier which maps to 
the calling number. 

13. A method according to any one of claims 4 to 12 wherein the identifier of the 
action comprises the called number, the method comprising extracting the called 
number from a request for the action. 

14. A method according to daim 13 wherein the request contains an Identifier which 
maps to the called number. 

15. A method according to claim 14 wherein the request message may be received 
from any one of an e-mail client, a web client, an SiVIS client, a SOAP/HTTP 
client, or a WAP client. 

16. A method according to any one of claims 2 to 15 IP routing device is preferably 
controlled using SIP messages. 

17. A method according to any preceding claim further comprising receiving a request 
to establish a call connection at a web server, said request including the identifier 
of the calling number and the identifier of the action; verifying said request at the 
web sen/er; transmitting said request In XML message format to a call controller 
controlling an IP router using SIP message, establishing the communication linl< 
to the calling number at the IP router under the control of the call cdntroller. 
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18. A method according to claim 17 when dependent upon any one of claims 4 to 16 
any further comprising establishing the communication link to the called number 
at the IP router under the control of the call controller, and controlling the IP router 
tp connect the established communication links internally. 

5 19. A method according to claim 17 when dependent upon any one of claims 6 to 16 
wherein the IP routing device may route said PSTN connection to a mixing server 
adapted to receive the streamed sendee. 

20. A method according to claim 17 when dependent upon any one of claims 8 to 16 
further comprising establishing communication links to the called numbers at the 

10 IP router under the control of the call controller, and controlling the IP router to 
connect the established communication links to a mixer in the IP domain, and 
mixing the established communication links under the control of the call controller. 

21. A communication element adapted to establish a communication between at least 
two end-points, comprising: means adapted for receiving a request Including an 

15 identifier of a calling number and an Identifier of an action; means adapted for 
establishing a communication link to the calling number; means adapted for 
determining a communication link In dependence on said action; and means 
adapted for connecting the communication links in an IP domain. 

22. A communication element according to claim 21, wherein the request is an XML 
20 message, the means adapted for establishing a communication link to the calling 

number and the means adapted for connecting the communication links in an IP 
domain comprising control means for transmitting SIP messages to an IP router. 

23. A communication element according to claim 22, wherein if the action Is to 
establish a call between a calling party and a called party, the SIP messages 

25 instruct the IP router to establish a PSTN connection to each party and connect 
such connections internally. 

24. A communication element according to claim 22, wherein if the action is to 
establish' a call between a calling party and multiple called parties, the SIP 
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messages instruct the IP router to establish a PSTN connection to each party and 
route such connections to a mixer in the iP domain. 

25. A communication element according to claim 22, wherein If the action is to 
establish a connection for the calling party to a streamed service, the SIP 
messages Instruct the IP router to establish a PSTN connection to the calling 
party and route such connections to a mixer in the IP domain adapted to receive 
the streamed service. 

26. A communication element according to any one of claims 21 to 25 wherein the 
element is a switching server. 

27. A communication element adapted to control the establishment of a 
communication between at least two end-points, comprising: means adapted for 
receiving a request including an identifier of a calling number and an identifier of 
an action; means adapted for verifying the request, and means adapted to 
transmit said request in XML format messages to an element for establishing the 
communication. 

28. A communication element according to claim 27 wherein the request comprises a 
message from any one of an e-mail client, a web client, an SiVIS client, a 
SOAP/HTTP client, or a WAP client 

29. An IP router adapted to establish of a communication between at least two end- 
points, the router being adapted to establish a PSTN communication iinic to a first 
end-point, establish a communication link to a second end-point, and connect said 
established communications Internally. 

30. A communication system adapted to establishing a communication between at 
least two end-points, comprising: a control server for receiving a request including 
an identifier of a calling number of one end-point and an Identifier of an action, 
and adapted to transmit said request In XML format in dependence upon said 
action, a switching control server for receiving the request in XML format; an IP 
router operating under the control of SIP messages from the switching control 
server; the IP router being controlled for establishing a first communication linl< to 
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the calling number of the one end-point; wherein the switching controller further 
controls the IP router to connect the established communication link to the other 
end-point. 
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Abstract 

There is disclosed a communication system adapted to estabiisliing a communication 
between at least two end-points, comprising: a control server for receiving a request 
5 including an identifier of a calling number of one end-point and an identifier of an 
action, and adapted to transmit said request in XML fonmat in dependence upon said 
action, a switching control server for receiving the request in XML format; an IP router 
operating under the control of SIP messages from the switching control server; the IP 
router being controlled for establishing a first communication link to the calling 
10 number of the one end-point; wherein the switching controller further controls the IP 
router to connect the established communication link to the other end-point. 

[Figure 1] 
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